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METHOD AND APPARATUS FOR GENERATING A DEVICE USER 
INTERFACE 

5 FIELD OF THE INVENTION 

The present invention generally relates to the field of information handling 
systems, and particularly to a user interface for an information handling system. 

BACKGROUND OF THE INVENTION 

10 Information handling systems are increasingly utilized as a central control unit 

for multimedia devices. Typical multimedia devices include media players such as 
audio amplifiers, receivers, videocassette recorders (VCRs), compact disc (CD) 
players, digital versatile disc (DVD) players, audio equalizers, audio and video 
processing systems, etc. Since multimedia devices are manufactured by a variety of 

15 manufacturers, many features offered by the manufacturer of one type of media 
device are not included with the same type of device from a different manufacturer. 
Further, the same manufacturer of multiple models of the same type of media device 
does not always provide the same features and functions for all of those devices. 
Therefore, only a common denominator of functions exists in each of a single type of 

20 media device. For example, the common denominator for VCR devices includes the 
"play", "stop", "pause", "fast forward" and "rewind" functions. Other functions may 
or may not exist on any particular media device. 

Existing user interfaces for managing multimedia devices with an information 
handling system are forced into only providing the common denominator functions 

25 for a given category of devices. As a result, these user interfaces cannot exploit the 
rich variety of features and functions included with many of the latest models of 
media devices, thereby limiting the usefulness of managing the multimedia devices 
with an information handling system. Thus, there lies a need for a user interface 
which is capable of providing control of all, or nearly all, of the available functions of 

30 multimedia devices beyond the common denominator functions of the category of 
media devices. 
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SUMMARY OF THE INVENTION 
The present invention is directed to a system for generating a device user 
interface executable by an information handling system. In one embodiment, the 
system includes a processor for executing instructions on the information handling 
5 system and a memory coupled to the processor for storing instructions executed by 
the processor, a device database including a list of devices for which user interface 
components are available to implement functions for controlling the devices, a 
resource database including the user interface components, a user interface generator 
for determining whether the device is included in the device database and for 
10 retrieving the user interface components from the resource database, and a layout 
manager for assembling the user interface components retrieved by the user interface 
generator into a user interface executable by the information handling system to 
control the device. 

The present invention is further directed to a method for generating a device 
15 user interface executable by an information handling system. In one embodiment, the 
method includes steps for identifying the device coupled to the information handling 
system to be controlled by the user interface, comparing the identified device to a 
database of devices for which user interface resource components are available for 
implementing the functions of the device and determining whether the device is listed 
20 in the database, in the event the device is not listed in the database, retrieving generic 
device user interface components for devices of the type of the identified device, 
otherwise, retrieving user interface components for implementing specific functions 
of the device, assembling the user interface components into a layout matrix, and 
creating the user interface from the layout matrix of the assembled user interface 
25 components 

It is to be understood that both the forgoing general description and the 
following detailed description are exemplary and explanatory only and are not 
restrictive of the invention as claimed. The accompanying drawings, which are 
incorporated in and constitute a part of the specification, illustrate an embodiment of 
30 the invention and together with the general description, serve to explain the principles 
of the invention. 
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BRIEF DESCRIPTION OF THE DRAWING 
The numerous advantages of the present invention may be better understood 
by those skilled in the art by reference to the accompanying figures in which: 

FIG. 1 is a block diagram of an information handling system operable to 
5 embody the present invention; 

FIG. 2 is a block diagram of a system for automatically generating a user 
interface for a device of an information handling system in accordance with the 
present invention; 

FIG. 3 is a flow diagram of a method for generating a device user interface in 
10 accordance with the present invention; and 

FIG. 4 is a block diagram of the assembly of a user interface from device 
function objects in accordance with the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 

15 Reference will now be made in detail to the presently preferred embodiment of 

the invention, an example of which is illustrated in the accompanying drawings. 

Referring now to FIG. 1, a hardware system of an information handling 
system in accordance with the present invention is shown. The hardware system 
shown in FIG. 1 is generally representative of the hardware architecture of an 

20 information handling system of the present invention. A central processing system 
102 controls the information handling system 100. Central processing system 102 
includes a central processing unit such as a microprocessor or microcontroller for 
executing programs, performing data manipulations and controlling the tasks of 
information handling system 100. Communication with central processor 102 is 

25 implemented through a system bus 110 for transferring information among the 
components of information handling system 100. Bus 110 may include a data channel 
for facilitating information transfer between storage and other peripheral components 
of information handling system 100. Bus 110 further provides the set of signals 
required for communication with central processing system 1 02 including a data bus, 

30 address bus, and control bus. Bus 110 may comprise any state of the art bus 
architecture according to promulgated standards, for example industry standard 
architecture (ISA), extended industry standard architecture (EISA), Micro Channel 
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Architecture (MCA), peripheral component interconnect (PCI) local bus, standards 
promulgated by the Institute of Electrical and Electronics Engineers (IEEE) including 
IEEE 488 general-purpose interface bus (GPIB), IEEE 696/S-100, and so on. 

Other components of information handling system 100 include main memory 
5 104, auxiliary memory 106, and an auxiliary processing system 108 as required. 
Main memory 104 provides storage of instructions and data for programs executing 
on central processing system 102. Main memory 104 is typically semiconductor 
based memory such as dynamic random access memory (DRAM) and or static 
random access memory (SRAM). Auxiliary memory 106 provides storage of 

10 instructions and data that are loaded into the main memory 104 before execution. 
Auxiliary memory 106 may include semiconductor based memory such as read-only 
memory (ROM), programmable read-only memory (PROM) erasable programmable 
read-only memory (EPROM), electrically erasable read-only memory (EEPROM), or 
flash memory (block oriented memory similar to EEPROM). Auxiliary memory 106 

15 may also include a variety of non-semiconductor based memories, including but not 
limited to magnetic tape, drum, floppy disk, hard disk, optical, laser disk, compact 
disc read-only memory (CD-ROM), digital versatile disk read-only memory (DVD- 
ROM), digital versatile disk random-access memory (DVD-RAM), etc. Other 
varieties of memory devices are contemplated as well. Information handling system 

20 100 may optionally include an auxiliary processing system 108 which may be a 
digital signal processor (a special-purpose microprocessor having an architecture 
suitable for fast execution of signal processing algorithms), a back-end processor (a 
slave processor subordinate to the main processing system), an additional 
microprocessor or controller for dual or multiple processor systems, or a coprocessor. 

25 Information handling system 100 further includes a display system 112 for 

connecting to a display device 114, and an input/output (I/O) system 116 for 
connecting to one or more I/O devices 118, 120 up to TV number of I/O devices 122. 
Display system 112 may comprise a video display adapter having all of the 
components for driving the display device, including video random access memory 

30 (VRAM), buffer, and graphics engine as desired. Display device 1 14 may comprise a 
cathode ray-tube (CRT) type display such as a monitor or television, or may comprise 
alternative type of display technologies such as a liquid-crystal display (LCD), a light- 
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emitting diode (LED) display, or a gas or plasma display. Input/output system 116 
may comprise one or more controllers or adapters for providing interface functions 
between one or more of I/O devices 118-122. For example, input/output system 116 
may comprise a serial port, parallel port, infrared port, network adapter, printer 
5 adapter, radio-frequency (RF) communications adapter, universal asynchronous 
receiver-transmitter (UART) port, etc., for interfacing between corresponding I/O 
devices such as a mouse, joystick, trackball, trackpad, trackstick, infrared transducers, 
printer, modem, RF modem, bar code reader, charge-coupled device (CCD) reader, 
scanner, compact disc (CD), compact disc read-only memory (CD-ROM), digital 

10 versatile disc (DVD), video capture device, touch screen, stylus, electro acoustic 
transducer, microphone, speaker, etc. Input/output system 116 and I/O devices 118- 
122 may provide or receive analog or digital signals for communication between 
information handling system 100 of the present invention and external devices, 
networks, or information sources. Input/output system 116 and I/O devices 118-122 

15 preferably implement industry promulgated architecture standards, including 
Recommended Standard 232 (RS-232) promulgated by the Electrical Industries 
Association, Infrared Data Association (IrDA) standards, Ethernet IEEE 802 
standards (e.g., IEEE 802.3 for broadband and baseband networks, IEEE 802. 3z for 
Gigabit Ethernet, IEEE 802.4 for token passing bus networks, IEEE 802.5 for token 

20 ring networks, IEEE 802.6 for metropolitan area networks, 802.11 for wireless 
networks, and so on), Fibre Channel, digital subscriber line (DSL), asymmetric digital 
subscriber line (ASDL), frame relay, asynchronous transfer mode (ATM), integrated 
digital services network (ISDN), personal communications services (PCS), 
transmission control protocol/Internet protocol (TCP/IP), serial line Internet 

25 protocol/point to point protocol (SLIP/PPP), and so on. It should be appreciated that 
modification or reconfiguration of information handling system 100 of FIG. 1 by one 
having ordinary skill in the art would not depart from the scope or the spirit of the 
present invention. 

Referring now to FIG. 2, a system for automatically generating a user interface 
30 for a device of an information handling system in accordance with the present 
invention will be discussed. The system 200 represents the preferred embodiment in 
which an application 210 running on information handling system 210 is used to 
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control a device connected to information handling system 100. The device may be 
an input device, output device, or an input/output (I/O) device 122 coupled to 
information handling system 100. Typically, device 122 is a multimedia device 
coupled to information handling system 100 such that control of device 122 may be 
5 provided by the information handling system. For example, a user of information 
handling system may utilize a remote input device such as a wireless mouse or 
keyboard, represented for example as I/O device 1 18, to enter a control command into 
information handling system in order to operate device 122. Device 122 may be a 
DVD player coupled to information handling system 100. The user may enter a 

10 "play" command with the input device in order to initiate the playback of a DVD disc 
disposed in the DVD player. Application 210 receives the command and controls the 
DVD player to initiate playback of the DVD disc. The user is allowed to select from 
the group of commands or functions that are available to control device 122 by 
application 210 that provides a user interface 232 for displaying the group of 

15 commands and for executing a selected command. Application 210 may be initiated, 
for example, when a new device is coupled to information handling system 100 or 
when device 122 is powered on such that an appropriate user interface 232 may be 
generated by user interface generator 212. Alternatively, a user may cause the 
initiation of application 210 by causing the application to be executed by information 

20 handling system 100 (e.g., via an input command). Upon initiation, application 210 
calls user interface generator 212 to generate an appropriate user interface 232 for 
controlling device 122. User interface generator 212 accesses a device database 214 
that contains a list of known devices 216-220. Device database 214 contains a list of 
devices 216-220 for which control functions beyond the common denominator of 

25 functions of classes of devices are known. For example, device database 214 may be 
a registry stored in an information storage medium (e.g., auxiliary memory 106) of 
information handling system 100 containing a list of devices coupled to information 
handling system 100 and all of the functions that devices 216-220 are capable of 
providing. Device database 214 may be automatically generated by a program of 

30 instructions (e.g., an operating system) executing on information handling system 100 
without requiring user intervention, or may be generated or modified by the user. A 
user interface (UI) resource database 222 contains a list of available functions 224- 
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228 that are known for devices 216-220 listed in device database 214 that are 
provided as modular user interface objects, including common denominator functions, 
for each of the functions provided by devices 216-220 stored in device database 214. 
One or more functions, both common denominator functions and unique functions, 
5 may be structured in the form of an object, a self contained data structure that includes 
data about the device and procedures or instructions for controlling or manipulating 
the device. Such objects are known in the art of object-oriented programming in 
which a data structure is defined by the type of data that it contains and by the types 
of operations that can be applied to the data structure. Objects are therefore modules 

10 that, once created, need not be changed or redefined when another object is created or 
defined. Object modules are thus easily combined into a larger program of 
instructions. Thus, a first object may provide data and instructions for common 
denominator functions for controlling a recording device (e.g., play, record). A 
second object may provide data and instructions for controlling a particular function 

15 for a recording device (e.g., video freeze frame). User interface generator 212 creates 
the objects as modular interfaces based upon device database 214 and stores the 
objects in UI resource database 222. User interface generator 212 may then retrieve 
the modular user interface objects from UI resource database 222 and combine the 
objects to form a complete user interface 232 for all, or nearly all, functions of 

20 devices 216 listed in device database. 

For example, device 122 may be a particular make and model of videocassette 
recorder (VCR). Data about that particular make and model of the VCR may be 
stored in device database 214. Storage of a particular make and model of the VCR in 
device database 214 indicates that the control functions 224-228 of that particular 

25 make and model of VCR are stored in user interface resource database as user 
interface objects. The control functions include "play", "fast forward", "frame speed 
adjust", "stop", "rewind", "tape speed adjust", "pause", "frame advance", and 
"menus". A combination of user interface components is contained in UI resource 
database 222 from which a user interface may be created (see FIG. 4). For example, a 

30 first UI component may provide control of "play", "stop", "pause", "fast forward", 
"rewind", and "frame advance" functions. This first UI component provides the 
common denominator functions common to all VCR's in general. A second UI 
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component may provide control of "frame speed" functions. This function may be 
provided only for certain models of VCRs, but not all. Similarly, a third UI 
component may provide control of "tape speed adjustment" functions, and a fourth UI 
component may provide "menu" control functions for a particular make and model of 
5 VCR. User interface generator 212 retrieves the UI components from UI resource 
database 222 combining the functions 224-228 provided by the retrieved UI 
components to correspond to the available control functions for the device as listed in 
device database 214. The retrieved UI components are sent to a layout manager 230 
that assembles the UI components into a user interface 232 (see FIG. 4). User 

10 interface 232 provides user control of the combination of functions for the selected 
device, for example, PLAY, STOP, PAUSE, FF, REW, and FA buttons to receive 
input commands from the user to execute the corresponding functions. Further, 
resulting user interface 232 may include a frame speed slider, a tape speed selector, 
and set up menu items to provide the additional functions available for the selected 

15 device. The user may then operate the device by entering the proper input commands 
using a coordinate position input device (e.g., mouse). When application 210 is used 
to control a different device, user interface generator 212 generates a new user 
interface customized for that particular, different device. 

Application 210, user interface generator 212, layout manager 230 and user 

20 interface 232 may be embodied as a software program executed by central processing 
system 102 of information handling system 100. Device database 214 and user 
interface resource database 222 are preferably stored in main memory 104 or auxiliary 
memory 106 of information handling system. As necessary, device database 214 and 
UI resource database 222 may be maintained or updated via an information storage 

25 medium coupled to information handling system 100 (e.g., floppy disk, CD-ROM, 
ROM device) wherein the information storage medium contains updated device and 
UI resource information and routines for functions 228 of devices 220. Further, 
device database 214 and UI resource database 222 may be updated via information 
downloaded into information handling system 100 from a remote device coupled to 

30 information handling system 100 via a network (e.g., the Internet) coupled to 
input/output system 116. 
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Referring now to FIG. 3, a flow diagram of a method for generating a device 
user interface in accordance with the present invention will be discussed. The method 
300 initiates when an application is run at step 310 for controlling a device coupled to 
information handling system 100. The type of device, and the make and model of the 
5 device are determined at step 3 12. For example, the device name may be entered by a 
user or provided by the device itself e.g., from a ROM chip disposed in the device 
having data of the device type that is readable by information handling system 100. 
After determination of the device, the device is compared at step 314 to device 
database 214 for which functions of the device are known and for which user interface 

10 components are available to implement those functions in a user interface. A 
determination is made at step 316 whether the determined device is listed in database 
214 of known devices. In the event the device is not listed in device database 214, a 
determination is made at step 318 whether the determined device is similar to a device 
listed in device database 214. For example, information handling system 100 may 

15 test the device to determine the type of functions that the device is capable of 
executing, or the user may enter what the device is generically (e.g., "VCR"). If a test 
for a VCR recording function is sent to the device and the device returns a signal 
indicating that the device is recording, then a determination may be made that the 
device is a VCR. Further, application 210 may determine, or the user may select, the 

20 closest device match in database by matching the device to the closest device already 
existing in database 214. In the event the device is not similar to a device listed in 
device database 214, generic device user interface components are retrieved at step 
320 from user interface resource database 222. The retrieved generic device UI 
components provide those functions that are common to all devices of the determined 

25 type of device. Otherwise, the device specific UI components for implementing the 
functions of the determined device as listed in device database 214 are retrieved at 
step 322 from UI resource database 222. Layout manager 230 places the retrieved UI 
components into a layout matrix at step 324 and creates a user interface 232 at step 
326 for implementing the functions available for the determined device. User 

30 interface 232 may be generated automatically without requiring any intervention by 
the user. Method 300 may be implemented as a program of instructions stored in 
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main memory 104 or auxiliary memory 106 and executed by central processing 
system 102 or auxiliary processing system 108. 

Referring now to FIG. 4, a block diagram of the assembly of a user interface 
from device function objects in accordance with the present invention will be 
5 discussed. UI resource database 222 contains one or more objects that incorporate the 
functions 224-228 of devices 216-220. For example, a first object 410 may be 
defined for a first class of devices 416 such as all VCRs. Object 410 may contain data 
422 for common denominator functions 422 as a common set of instructions for 
controlling the class of all VCRs. The common denominator functions 428 may 

10 include instructions for implementing play, stop, pause, record, fast forward, and 
rewind functions for all VCRs. A second object 412 may be defined for a second 
class of devices 418 such as VCRs compliant with a first standard. Such devices may 
provide freeze frame functions 424 that include instructions 430 for holding and 
releasing a video image. A third object 414 may be defined for a third class of 

15 devices 420 such as VCRs compliant with a second standard. Such devices may 
provide a reverse play function 428 that include instructions for causing a VCR of 
class 420 to reverse play a video signal. Layout manager 230 is called by user 
interface generator 212 for assembling a user interface 232 based upon available 
functions for a given device. The given device may be a VCR compliant with the first 

20 and second standards. User interface generator 212 passes objects 410, 412 and 414 
to layout manager 230 that assembles a user interface for controlling the VCR based 
upon the VCR functions provided by objects 410, 412 and 414. For example, layout 
manager 230 may assemble user interface by assembling icons corresponding to the 
functions 428, 430 and 432 of objects 410, 412 and 414, respectively. As shown in 

25 FIG. 4, user interface 232 may include icons for implementing common denominator 
functions (play 436, stop 442, pause 448, record 438, fast forward 444, and rewind 
450), for implementing freeze frame functions (freeze frame release 440, freeze frame 
hold 446) and for implementing a reverse play function (reverse play 452). When a 
user selects an icon of user interface 232, information handling system 100 executes 

30 the corresponding instruction and thereby controls the VCR by calling the object 
having the corresponding instruction. 



98-0674 



11 



Although the invention has been described with a certain degree of 
particularity, it should be recognized that elements thereof may be altered by persons 
skilled in the art without departing from the spirit and scope of the invention. One of 
the embodiments of the invention can be implemented as sets of instructions resident 
5 in the main memory 104 of one or more computer systems configured generally as 
described in FIG. 1 . Until required by the computer system, the set of instructions 
may be stored in another computer readable memory such as auxiliary memory 106 of 
FIG. 1, for example in a hard disk drive or in a removable memory such as an optical 
disk for utilization in a CD-ROM drive, a floppy disk for utilization in a floppy disk 

10 drive, a floptical disk for utilization in a floptical drive, or a personal computer 
memory card for utilization in a personal computer card slot. Further, the set of 
instructions can be stored in the memory of another computer and transmitted over a 
local area network or a wide area network, such as the Internet, when desired by the 
user. Additionally, the instructions may be transmitted over a network in the form of 

15 an applet (a program executed from within another application) or a servlet (an applet 
executed by a server) that is interpreted or compiled after transmission to the 
computer system rather than prior to transmission. One skilled in the art would 
appreciate that the physical storage of the sets of instructions or applets physically 
changes the medium upon which it is stored electrically, magnetically, chemically, 

20 physically, optically or holographically so that the medium carries computer readable 
information. 

It is believed that the method and apparatus for automatically generating a 
device user interface of the present invention and many of its attendant advantages 
will be understood by the forgoing description, and it will be apparent that various 
25 changes may be made in the form, construction and arrangement of the components 
thereof without departing from the scope and spirit of the invention or without 
sacrificing all of its material advantages, the form herein before described being 
merely an explanatory embodiment thereof. It is the intention of the following claims 
to encompass and include such changes. 

30 
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What is claimed is: 



CLAIMS 



1 1. A system for generating a device user interface executable by an 

2 information handling system, comprising: 

3 a processor for executing instructions on the information handling system and 

4 a memory coupled to said processor for storing instructions for execution by said 

5 processor; 

6 a device database including listing available user interface components for 

7 implementing control functions of a device coupled to the information handling 

8 system; 

9 a resource database including the user interface components; 

10 a user interface generator for determining whether the device is included in 

11 said device database and for retrieving the user interface components for that device 

12 from said resource database; and 

13 a layout manager for assembling the user interface components retrieved by 

14 said user interface generator into a user interface executable by the information 

15 handling system to control the device. 

1 2. A system as claimed in claim 1, wherein the device is a multimedia 

2 device controlled by the information handling system. 

1 3. A system as claimed in claim 1, wherein said device database is 

2 created without requiring user intervention. 

1 4. A system as claimed in claim 1, wherein said resource database is 

2 created without requiring user intervention. 

1 5 . A system as claimed in claim 1 , wherein the user interface components 

2 of said resource database comprise discrete objects. 
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1 6. A system for generating a device user interface executable by an 

2 information handling system, comprising: 

3 means for executing instructions on the information handling system and 

4 means, coupled to said executing means, for storing instructions for execution by said 

5 processor; 

6 means for listing available means for implementing control functions of a 

7 device coupled to the information handling system; 

8 means for storing the implementing means; 

9 means for determining whether the device is included in said device list 

10 storing means, and for retrieving the implementing means from said implementing 

1 1 means storage means; and 

12 means for assembling the implementing means retrieved by said determining 

13 and generating means into a user interface executable by the information handling 

14 system to control the device. 

1 7. A system as claimed in claim 6, wherein the device is a multimedia 

2 device controlled by the information handling system. 

1 8. A system as claimed in claim 6, wherein said device list storing means 

2 is created without requiring user intervention. 

1 9. A system as claimed in claim 6, wherein said implementing means 

2 storing means is created without requiring user intervention. 

1 10. A system as claimed in claim 6, wherein the implementing means 

2 comprises a discrete object variable. 
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1 1 1 . A computer implemented method for generating a device user interface 

2 for an information handling system, comprising: 

3 identifying a device coupled to the information handling system to be 

4 controlled by the user interface; 

5 comparing the identified device to a database of devices for which user 

6 interface resource components are available for implementing the functions of the 

7 device and determining whether the device is listed in the database; 

8 retrieving user interface components for implementing functions of the device; 

9 and 

1 0 creating the user interface from the user interface components. 

1 12. A method as claimed in claim 11, further comprising the steps of, in 

2 the event the device is not listed in the database, determining whether a similar device 

3 similar to the device is listed in the database; in the event a similar device is not listed 

4 in the database, executing said generic device user interface components retrieving 

5 step; otherwise, executing said device specific user interface components retrieving 

6 step. 

1 13. A method as claimed in claim 11, further comprising the step of 

2 displaying the user interface on a display coupled to the information handling system 

3 such that a user may control the device with the user interface. 

1 14. A method as claimed in claim 11, said creating step being implemented 

2 without requiring user intervention. 

1 15. A method as claimed in claim 11, the user interface components 

2 comprising discrete objects. 
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1 16. A computer implemented program of instructions storable on a 

2 computer readable medium and executable by an information handling system, the 

3 contents of the program of instructions causing an information handling system to 

4 execute steps for generating a device user interface for the information handling 

5 system, the steps comprising: 

6 identifying the device coupled to the information handling system to be 

7 controlled by the user interface; 

8 comparing the identified device to a database of devices for which user 

9 interface resource components are available for implementing the functions of the 

1 0 device and determining whether the device is listed in the database; 

11 retrieving user interface components for implementing specific functions of 

12 the device; and 

13 creating the user interface from the assembled user interface components. 

1 17. A program of instructions as claimed in claim 16, the steps further 

2 comprising the steps of, in the event the device is not listed in the database, 

3 determining whether a similar device similar to the device is listed in the database; in 

4 the event a similar device is not listed in the database, executing said generic device 

5 user interface components retrieving step; otherwise, executing said device specific 

6 user interface components retrieving step. 

1 18. A program of instructions as claimed in claim 16, the steps further 

2 comprising the step of displaying the user interface on a display coupled to the 

3 information handling system such that a user may control the device with the user 

4 interface. 

1 19. A program of instructions as claimed in claim 16, said assembling step 

2 being implemented without requiring user intervention. 

1 20. A program of instructions as claimed in claim 16, the user interface 

2 components comprising discrete objects. 
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METHOD AND APPARATUS FOR AUTOMATICALLY GENERATING A 
DEVICE USER INTERFACE 



5 ABSTRACT 

A system and a method generate a device user interface executable by an 
information handling system. A device database includes a list of devices for which 
user interface components are available to implement functions for controlling the 
devices, and a resource database includes the user interface components. The device 

10 to be controlled by the user interface is identified and compared to a database of 
devices for which user interface resource components are available. A user interface 
generator determines whether the device is included in the device database and 
retrieves the user interface components from the resource database. A layout manager 
assembles the user interface components into a user interface. If the device is not 

15 listed, generic device user interface components are retrieved, otherwise device 
specific user interface components are retrieved, and assembled into a layout matrix. 
The user interface is created from the layout matrix. 



98-0674 



17 



1/4 
GROOTERS 
95-0674 




2/4 
9&-0674- 





CXI 

















U < 






o 




o 


<9&<9 


> 


^ < 

































3/4 
9&-0674 




PLACE UI 
COMPONENTS INTO 
LAYOUT MATRIX 



326 



DISPLAY USER 
INTERFACE 



FIG. 3 



4/4 
95-0674 



CLASS: I 

ALL VCRS I 





22 /-^42 






COMMON 




PLAY, STOP, PAUSE, 


DENOMINATOR 




RECORD, FAST 


FUNCTIONS 




FORWARD, REWIND 



^ 2 



FREEZE 
FRAME 



H CLASS: VCR I 
STANDARD 1 I 

-414 ^-A7.0 ^-4 

H REVERSE I 
FLAY I" 



I HOLD, I 

I RELEASE I 



CLASS: VCR I 
STANDARD 2| 



REVERSE 
PLAY 



LAYOUT 
MANAGER 



PLAY ^ I STOP 

433 



I \ | FORWARD \ | REW ' NP \ 



FREEZE FRAME 
RELEASE 



FREEZE 
FRAME F 



ZE p REVERSE | 

hold! play I 



FIG. 4 



Docket No.: 98-0674 



PATENT APPLICATION 



RULES 63 AND 67 (37 C.F.R. 1.63 and 1.67) 
DECLARATION AND POWER OF ATTORNEY 

FOR UTILITY/DESIGN/CIP/PCT NATIONAL APPLICATIONS 

As a below named inventor, I hereby declare that: 
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to me to be material to patentability of the application as defined in 37 CFR § 1.56 which 
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international filing date of this CIP application. 

I hereby claim foreign priority benefits under 35 U.S.C. § 119/365 of any foreign 
application(s) for patent or inventor's certificate listed below and have also identified below 
any foreign application for patent or inventor's certificate filed by me or my assignee 
disclosing the subject matter claimed in this application and having a filing date (1) before that 
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directly with the person/assignee/attorney /firm/organization who/which first sent this case to 
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punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United 
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application or any patent issued thereon. 
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